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general information 



1.1 INTRODUCTION 

This manual provides the information necessary to install the PM-XCV21/XCV31 
dual density controller. This controller is compatible with the DEC* RXV02 
floppy disc system. The PM-XCV21/XCV31, when configured with Shugart 800 
series drives, is a direct replacement for the RXV211 floppy disc system. 
There is no DEC replacement (at this time of release) for the PM-XCV21/XCV31 
when configured with Shugart 850 series double-sided drives. The PM-XCV21/ 
XCV31 controller is manufactured by Plessey Peripheral Systems, Irvine, 
California 92714. 

The information is arranged in four sections as follows: 

Section 1 - GENERAL INFORMATION. This section contains a brief general 
description of the controller, its features, components, compatibility, 
diskette format, and specifications. 

Section 2 - INSTALLATION AND CHECKOUT. This section describes the controller 
configuration, drive configuration, cabling, controller installation, opera¬ 
tion, and checkout. 

Section 3 - FUNCTIONAL DESCRIPTION. This section contains a detailed descrip¬ 
tion of the device registers and command protocol for the PM-XCV21/XCV31. 

Section 4 - CONTROLLER OPERATIONS. This section provides the pertinent 
information that is concerned with the description and use of the controller 
functions, controller operation, and operation using the RT-11. 


1.2 GENERAL INFORMATION 

The PM-XCV21/XCV31 is a dual density controller compatible with the DEC RXV02 
floppy disc system. Configured with any Shugart compatible drive, it is a 
direct replacement for the RXV211 subsystem. The controller provides either 
single density encoding compatible with IBM 3740 equipment, double density 
encoding, or double-sided double density recording for up to 1 Mbyte storage. 
When configured with two drives, each drive may operate at a different density. 

All electronics are contained on one dual-wide board which plugs directly into 
any standard LSI backplane and interfaces through a 50 conductor ribbon cable 
to any Shugart compatible drive. All controllers are tested and ready for 
plug-in and operation. The controller is configured for the standard device 
address 177170g and interrupt vector 264g . The interrupt level is factory set 
to level four. 


*Trademark of Digital Equipment Corporation. 
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1.2.1 FEATURES OF THE PM-XCV21/XCV31 

• Transparent firmware bootstrap automatically loads either single or double 
density diskettes. 

• Formatting capability permits writing sector headers, checking the written 
headers, and writing the data fields in the user selected density. 

• Jumpers allow user selection of both the alternate address and vector. 

• Jumper selectable four-level device interrupt priority compatible with the 
LSI-11/23*. 

• Provides power fail protection for data integrity. • 

• Write current control signal for tracks greater than forty-three. 

• Write precompensation for reduced error rates. 


1.3 COMPONENTS 

The controller is provided with the following components: 

P/N 703530 Floppy Disc Controller 

MA 703530 Manual 

MD 703530 Maintenance Drawing Package 

1.4 COMPATIBILITY 

This subsection discusses the aspects of hardware, software, and media compati¬ 
bility with Digital Equipment's RXV02 system. The information will aid the 
user in data interchange with non-DEC systems. 


1.4.1 HARDWARE 

The controller is compatible with the LSI-11*, LSI-11/2* and LSI-11/23 
processors. All circuitry is contained on one dual-wide board that plugs 
directly into any standard LSI-11 backplane. Alternate address selection and a 
four-level device interrupt priority scheme provide the user added flexibility 
for expanded system configurations. Shugart compatible drive logic is inter¬ 
faced through a 50-pin ribbon connector. The connector pins are compatible 
with both the 800 and 850 series drives. 


*Trademark of Digital Equipment Corporation 
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1.4.2 SOFTWARE 

The PM-XCV21/XCV31 is completely compatible with RXV211 register definition and 
command protocol. All DEC-supplied software designed to operate with the RXV02 
system will operate with the controller without modification. 


1.4.3 MEDIA 

The media used with the PM-XCV21/XCV31 is compatible with the IBM 3740 family 
of equipment. Either preformatted or blank soft sectored diskettes may be used 
with the controller. The following list summarizes the suggested media. 


Single Sided 

IBM 

Double Sided 

IBM 

RXV01/RXV02 

DEC 

DISKETTE FORMAT 



This subsection presents the diskette format and compatibility with DEC's RXV02 
type diskettes. 

1.5.1 LOGICAL TRACK FORMAT (REFER TO FIGURE 1-1) 

The diskette surface is divided into 77 concentric tracks numbered 0-76. Each 
track consists of 26 sectors numbered 1-26. The track begins and ends at the 
index address mark. The track is formatted in such a way that this "soft" 
index is preceded by the leading edge of the physical index hole in the 
diskette. Following the physical index are 40 bytes of "FF" data, 6 bytes of 
"0" data, and the index address mark indicating the beginning of the track. 
Following the index address mark is the post index gap consisting of 26 bytes 
of "FF" data and 6 bytes of "0" data. The next field is the sector header for 
sector 1. Following the sector header is the ID gap consisting of 11 bytes of 
"FF" data and 6 bytes of "0" data. The next field is the data record for 
sector 1. Following the data field is the data gap consisting of 28 bytes of 
"FF" data and 6 bytes of "0" data. This field leads to the next sector header. 
Following the 26th data record is the pre-index gap consisting of approximately 
274 bytes of "FF" data. 

Each track is formatted in the above manner (refer to Figure 1-1). The sector 
header field of each sector contains information describing both the sector and 
track number. All the above fields are recorded in FM except as noted in the 
following sections. 
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Figure 1-1. Logical Track Format 
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1.5.2 SECTOR HEADER FIELD 

The header field consists of 7 bytes of information. Preceding the header is a 

field of 6 bytes of "zero" data for synchronization. The header and this 

preamble are always recorded in FM. 

1. Byte 1. ID Address Mark - A unique mark consisting of 1 byte of FE (hex) 
data with three missing clock-transitions, using a C7 (hex) clock pattern. 
This mark is decoded by the controller and indicates the start of the 
sector header. 

2. Byte 2. Track Address - This byte indicates the absolute (0-114g) track 

address. Each sector contains this track information to locate its 

position on one of the 77 tracks. 

3. Byte 3. "Zero" 

4. Byte 4. Sector Address - This byte indicates the absolute (l-32g) sector 
address. Each sector contains this information to identify its position on 
the track. 

5. Byte 5. "Zero" 

6. Byte 6, 7. Cyclic Redundancy Check (CRC) - This is the 16 bit cyclic 

redundancy character and is calculated for each sector from the first 5 

bytes of information, using the IBM 3740 polynomial. (Refer to CRC, 
Section 1.5.7). 


1.5.3 DATA FIELD 

The data field consists of either 131 jo or 259io bytes of information depending 
upon the recording method. Preceding the data field is a field of 6 bytes of 
"zero" data for synchronization. 

The preamble and data address mark are always written in FM. The user data and 
CRC character are either written in FM or MFM modified depending upon the 
formatted diskette density. 

1. Byte 1: Data Address Mark - A unique mark consisting of a data byte (see 
Table 1-1) with three missing clock transitions, using a C7 (hex) clock 
pattern. This byte is always written in FM and is decoded by the 
controller to indicate the start of the data field, its recording method 
(FM vs MFM), and if the field is a deleted data field. 
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TABLE 1-1. ADDRESS MARKS 


Address 

Mark 

Indicated 

Density 

Data 

Clock 

INDEX 

NA 

FC 

C7 

ID 

NA 

FE 

C7 


FM 

FB 

C7 

DATA 

MFM 

Modified 

FD 

C7 

DELETED 

FM 

F8 

C7 

DATA 

MFM 

Modified 

F9 

C7 


2. Bytes 2-129 (FM) or Bytes 2-257 (MFM Modified): User Data - This field is 
recorded in either FM or MFM modified. Depending upon the encoding scheme, 
either 128 or 256 bytes of information can be stored. 

3. Bytes 130-131 or bytes 258-259 (MFM Modified): CRC - This is the 16-bit 
cycle redundancy character and is calculated for each data field from the 
first 129 or 257 bytes of information using the IBM 3740 polynomial (Refer 
to CRC, Section 1.5.7). These bytes are recorded with the same encoding 
scheme as the data field. 


1.5.4 RECORDING SCHEME 

Two recording schemes are used by the PM-XCV21/XCV31: double frequency (FM) 
and DEC modified Miller code (MFM). FM is used for single density recording 
and is compatible with IBM 3740 or DEC RXV01 media. DEC modified MFM is used 
for recording double density and is only compatible with the DEC RXV02 system. 


1.5.5 DOUBLE FREQUENCY (FM) 

FM recording is characterized by a flux transition at the beginning of each bit 
cell which is commonly termed a clock pulse or transition as shown in Figure 
1-2. A logic "one" is represented by a flux transition within the bit cell; a 
logic "zero" is represented by the lack of any flux transition within a bit 
cell. In FM the bit cell time is 4us. 


1-6 



MA 703530-A 


•• 0 " ” 0 " " 1 " " 0 " " 1 " " 0 " 


■■iiHHiraiHiinnn 


C C C D C CDC C 

8IT 
CELL 
4 ytiS 

Figure 1-2. FM Recording Characteristics 


1.5.6 DEC MODIFIED MFM 

MFM recording consists of flux transitions for a logic "one” and no flux 
transitions for a logic "zero". A clock transition only occurs between two 
consecutive logic "zeros" as shown in Figure 1-3 below. The MFM bit cell time 
is 2us. 





Figure 1-3. MFM Recording Characteristics 
Table 1-2 summarizes the standard MFM encoding algorithm. 


TABLE 1-2. STANDARD MFM ENCODING 
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Because single density headers are used for both FM and MFM recording formats, 
and since certain MFM patterns map into single density address marks, a 
modified algorithm is used. The mapping occurs when a data pattern of exacting 
four consecutive "ones" is encoded. Whenever this pattern is encoded, a 
special algorithm is applied. Table 1-3 defines the encoding algorithm for 
this special case. 


TABLE 1-3. MODIFYING ALGORITHM (SPECIAL CASE) 


Data 


DN-5 

DN-4 

DN-3 

DN-2 

DN-1 

DN 

0 

1 

1 

1 

1 

0 

X 0 

CN-5 DN-5 

1 0 
CN-4 DN-4 

0 0 
CN-3 DN-3 

1 0 
CN-2 DN-2 

0 0 
CN-1 DN-1 

1 0 

CN DN 


Encoded Data 


When reading double density data fields, the controller checks for a missing 
clock bit between two zero data cells, and if found, substitutes one's 
(generated by the special encoding algorithm) for the two zero data bits. 


1.5.7 CYCLIC REDUNDANCY CHECK (CRC) 

Each sector header field and data field has a two byte CRC character appended. 
This 16-bit character is the remainder that results when dividing the data bits 
[represented as a polynomial M(x)] by a generator polynomial G(x). The 
polynomial used for IBM 3740 is G(x) = X 16 + X 12 + X s + 1. For the sector header 
the data bits include byte 1 thru byte 5. For an FM data field, the data bits 
include byte 1 thru byte 129. For an MFM data field, the data bits include 
byte 1 thru byte 257. 
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1.6 SPECIFICATIONS 

RECORDING TECHNIQUE: 

Single Density 
Double Density 

POWER REQUIREMENTS: 

Voltage 

Current 

ENVIRONMENTAL: 

Temperature 

Humidity 


IBM 3740 FM 
DEC Modified MFM 


Single 5V supply 
(From LSI-11 backplane) 

Typical 2.5A 


0°C to 45°C 

10% - 95% non-condensing 
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installation and checkout 



2.1 CONTROLLER CONFIGURATION 

The PM-XCV21/XCV31 controller is shipped with standard options configured. The 
standard address 177170g and vector 264g are set. The device interrupt 
priority is set to level four. The firmware bootstrap is disabled. Write 
precompensation is enabled. Write current control is disabled. Both drive and 
side select options have been configured for either single- or double-sided 
drives. 

Most options are factory foil-etched to the most often used configuration. The 
foil jumpers must first be cut before the alternate jumpers are inserted. 
Refer to Tables 2-1, 2-2, and 2-3 for alternate options and Figure 2-1 for 
jumper location. Several of the options are selectable by using AMP 530153-2 
pin jumpers. If these pin jumpers are not available, use #30 wire wrap. 


TABLE 2-1. ADDRESS/VECTOR OPTION CONFIGURATION 


Option 

Jumper 

15-16 

16-17 

33-34 

Standard 

Address/Vector* 
177170/264 

IN 

OUT 

OUT 

Alternate 

Address/Vector 
177174/270 

OUT 

IN 

IN 


*Factory Preset 
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Drive 

Select 


Side Select 


1-2 2-3 4-55-6 


Bootstrap 

Enabled 

Bootstrap** 

Disabled 

Write Precomp** 
Enabled 

Write Precomp 
Disabled 

Write Current* 
Control Enabled 

Write Current** 
Control Disabled 

Single Sided 
Drives only 

Single or Double** 
Sided Drives 

One Double Sided 
Drive 

Drive 0 = Side 0 
Drive 1 = Side 1 


Out I In I Out Out In 


In Out Out 


In In I Out In Out 


l/M- 


*Should be enabled for double sided drives 

**Factory Preset 
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2.1.1 ADDRESS VECTOR SELECTION 

The controller is shipped with DEC standard device address and vector assign¬ 
ments preset to 177170g and 264g respectively. Any change in these assignments 
would necessitate a change in system software. However, an alternate address 
and vector assignment is selectable and is defined as 177174g and 270g 
respectively. 

These assignments are typically used when more than two drives are needed; two 
controllers would be required and the second controller would be configured for 
the alternate address and vector. To select the alternate address/vector, 
first cut the foil between W15 and W16, jumper W16 to W17, and jumper W33 to 
W34 as shown in Table 2-1. 


2.1.2 DEVICE INTERRUPT PRIORITY 

The PM-XCV21/XCV31 supports the four-level device interrupt priority scheme 
compatible with the LSI-11/23. The controller asserts interrupt requests and 
monitors higher level request lines during interrupt arbitration (refer to 
Table 2-2). The level four request is always asserted by the controller, 
regardless of its priority, to maintain compatibility with the LSI-11 
processors. 

The interrupt priority level is configured to level four at the factory. If a 
different interrupt level is desired, jumpers must be cut. Refer to Table 2-2 
for the proper jumpers to insert for the desired priority level. 


2.1.3 BOOTSTRAP 

The controller board incorporates a transparent firmware bootstrap. The 
bootstrap is initiated whenever program execution is started at location 
173000g, homing both drives to track 0. Next, track 1, sector 1, of unit 0 is 
read and diskette density is determined. If the diskette is single density, 
sectors 1, 3, 5, and 7 are loaded into memory starting at location 0. If the 
diskette is double density, sectors 1 and 3 are loaded. Program execution is 
then transferred to location 0. Controllers are shipped with this feature 
disabled. To enable the bootstrap, remove the jumper between W10 and W43 and 
insert the jumper between W10 and Wll as indicated in Table 2-3. 

Note 

Only one bootstrap should be enabled in a 
system for proper operation. If another 
bootstrap exists in the system, it must be 
disabled before enabling the controller 
bootstrap. 
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2.1.4 WRITE PRECOMPENSATION 

The PM-XCV21/XCV31 controller provides hardware write precompensation to reduce 
the bit shift exhibited by all drives as the recorded flux density increases. 
The controller recognizes the patterns which produce bit shift and precompen¬ 
sates the written pattern. This unique feature allows the controller to 
perform reliably with any Shugart compatible drive. 

Controllers are shipped with this feature enabled; it is recommended that this 
feature not be disabled for more reliable operation. However, if so desired, 
the feature can be defeated by cutting the foil-etched jumper between W13 and 
W14 and inserting a jumper between W12 and W13 as shown in Table 2-3. 


2.1.5 WRITE CURRENT CONTROL 

The PM-XCV21/XCV31 provides the necessary signal to reduce the write current 
for tracks greater than forty-three. This signal is available at pin 2 of the 
50-pin ribbon connector. 

Since the 800 series Shugart single-sided drive does not require a write 
current signal, the controller is shipped with this feature enabled. However, 
the double-sided 850 series drive does support write current control, and 
enabling this feature is recommended for reliable operation. This may be 
accomplished by jumpering pins W8 and W9 (refer to Figure 2-1). 



2.1.6 DRIVE AND SIDE SELECTION 

The controller features several options for both drive and side selection. The 
side select output can be disabled, allowing operation on single sided drives 
only, The controller, when shipped, is configured for either single or double 
sided drives. If double sided drives are used, proper jumpering allows a one 
double sided drive to be addressed as two drives where side 0 appears as drive 
1 and side 1 appears as drive 2. It is recommended that the write current 
control be enabled as described in subsection 2.1.5. Before selecting the 
double sided drive option, the jumper between W4 and W5 must be cut. For this 
configuration refer to Table 2-3. 
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2.2 DRIVE CONFIGURATION 

For proper operation, the floppy drives must be configured with attention to 
several options. The controller uses radial drive selection. Thus, the 
drive(s) should be correspondingly configured. When two drives are used, the 
first should be drive 0 and the second drive 1. A particular drive is selected 
and remains selected after a function is complete to allow the controller to 
poll drive status. A separate head load signal is provided by the controller 
for read and write functions on the diskette. The "in use" logic of the drive 
should be configured as a function of head loading. Since the drives are homed 
without loading the heads during an initialize command, the drive should be 
configured to provide stepper motor power independent of head loading. For 
details concerning these and other options refer to Table 2-4 (single-sided) 
and Table 2-5 (double-sided) drives. 


TABLE 2-4. DRIVE CONFIGURATION (SINGLE-SIDED) 


Option 

Description 

Dual 

Single 

Drive 0 

Drive 1 

Drive 0 


Drive select 1 

IN 

OUT 



Drive select 2 

OUT 

IN 



Drive select 3 

OUT 

OUT 



Drive select 4 

OUT 

OUT 



Radial head loading option 

IN 

IN 



Radial head loading option 

IN 

IN 

IN 


Head load option 

IN 

IN 

IN 


In use option 

OUT 

OUT 

OUT 

X 

Radial head loading option 

OUT 

OUT 

OUT 

WP 

Inhibit write when protect 

IN 

IN 

IN 

NP 

Allow write when protect 

OUT 

OUT 

OUT 

DS 

Stepper power from drive select 

IN 

IN • 

IN 

HL 

Stepper power from head load 

OUT 

OUT 

OUT 

Z 

• In use from drive select 

OUT 

OUT 

OUT 

Y 

In use from head load 

IN 

IN 

IN 

R 

Ready output 

IN 

IN 

IN 

I 

Index output 

IN 

IN 

IN 

DC 

Disc change output 

X 

X 

X 

S 

Sector output 

X 

X 

X 

800 

Sector option disable 

IN 

IN 

IN 

801 

Sector option enable 

OUT 

OUT 

OUT 

L 

-5V DC Bias 

IN 

IN 

IN 

T1 

Termination HL 

OUT 

IN 

IN 

T2 

Termination drive select 

IN 

IN 

IN 

T3 

Termination direction 

OUT 

IN 

IN 

T4 

Termination step 

OUT 

IN 

IN 

T5 

Termination write data 

OUT 

IN 

IN 

T6 

Termination write gate 

OUT 

IN 

IN 


X = Does not care 
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TABLE 2-5. DRIVE CONFIGURATION (DOUBLE-SIDED) 


Option 

DRO 

DR1 

TERM 5E 

* 

* 

DS1 

IN 


DS2 


IN 

2S 

IN 

IN 

RR 

IN 

IN 

R1 

IN 

IN 

850 

IN 

IN 

DC 



DS 

IN 

IN 

• WP 

IN 

IN 

DL 



C 

IN 

IN 

Y 

IN 

IN 

S2 

IN 

IN 

FS 

IN 

IN 

IW 

IN 

IN 

RS 

IN 

IN 

IT 

IN 

IN 

R 

IN 

IN \ 

I 

IN 

IN I 

S 

IN 

IN $ 

HL 


l 

A 

IN 

IN | 

B 

IN 

IN 1 

X 



Z 


/ 


STRAPPING PLUG 


* = MICRO III terminate DRO, 
all others DR1 
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2.3 CABLING 

A 50-conductor ribbon cable connects the controller to any Shugart compatible 
drive(s). If the optional cable is purchased with the controller, connect the 
socket connector to the 50-pin header located at the edge of the controller 
board. Observe the alignment of pin 1 of the socket connector and header as 
indicated by the arrows shown in Figure 2-2. The two 50-pin connectors should 
be connected to the corresponding drives, again observing the location of 
pin 1. If the optional cable is purchased from an independent source, the 
following list of materials (or equivalent) will help in the construction of 
the required cable. 


QTY 


DESCRIPTION 


MFG 


NUMBER 


1 ea 50-pin socket connector 3M 3425-3000 

2 ea 50-pin edge connector 3M 3415-0001 

A/R 50-conductor ribbon cable 3M 3365/50 



Figure 2-2. Drive/Controller Cabling 
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The connector pins illustrated in Figure 2-3 are compatible with both the 
Shugart 800 series and 850 series drives. Any drive that has both a Shugart 
compatible interface and connector should function properly with the 
controller. 



TG 43 


TWO SIDED 


SIDE SELECT 


HEAD LOAD 
INDEX 

READY 


DRIVE SELECT 1 
DRIVE SELECT 2 


DIRECTION 

STEP 

WRITE DATA 
WRITE GATE 
TRACK 00 
WRITE PROTECT 
READ DATA 


Figure 2-3. Connector Pin Definitions 
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2.4 CONTROLLER INSTALLATION 

The controller can be inserted and will function in any LSI-11 bus slot 
provided that both interrupt and DMA continuity is maintained. Since these 
signals are daisy chained through the bus slots, no unused slots between the 
LSI-11 processor and the floppy controller may exist. Determine the order that 
the priority chain follows by consulting the documentation supplied with the 
LSI-11 system. 

Note 

When two interrupts of the same priority 
level are asserted, the closer a device 
is located to the processor, the higher 
its priority level. 

2.5 CONTROLLER, INITIAL OPERATION AND CHECKOUT 

Before the following procedure are pursued, verify that the controller has been 
configured as described in Subsection 2.1 - 2.4. 

Note 

The bootstrap must be disabled for the 
following procedure: 

1. Apply AC and DC power to the drive(s). The spindle(s) should begin to 
rotate. The in-use indicators on both drives should be OFF. 

2. Place the Run/Halt switch on the processor to the Halt position and turn ON 
the processor. An "(a" character should be printed on the terminal signify¬ 
ing that console octal debugging technique (ODT) has been entered. Both 
drives (first drive 1, then drive 0) will step the heads inward 10-tracks; 
then the drives will step the heads outward until the home signal is 
detected. The heads will not load, and, if the drive is configured as per 
Subsection 2.2, the in-use indicators will not light. If the above events 
do not occur, check the cabling and drive power supplies. 

3. Place a performatted scratch diskette in drive 0. 

4. If the standard address assignment is selected, open the command and status 

(CS) register using ODT by typing 177170/ on the terminal. The processor 
will display the contents of the CS register. If the controller is 
operating properly, a 004040g should be pinted. Deposit an 40000g in the 
CS register by typing 40000 <CR>. This command will initialize the 

controller. Both drives should calibrate for home position. First, drive 
1 steps inward 10 tracks then outward one track at a time until the drive 
indicates track 0 has been reached. The procedure is repeated on drive 0. 
After both drives are calibrated, the head on drive 0 is loaded. Sector 1 
of track 1 on drive 0 is read into the controller buffer. This operation 
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is indicated by the in-use LED on the drive. Only the LED on drive 0 will 
be turned ON, indicating the head load operation. The LED will remain ON 
for a short time after the read operation is complete. 

If, after initializing, the drives do not calibrate or the LED is not 
activated, check the cabling and power supplies. 

5. Reopen the GS register (location 177170g), using ODT as described above. 
The contents of this location should be 004040s • Examining the next 
location 177172g by using the linefeed key or typing in 177172 <CR> sould 
yield either a 204g or 244g. For a detailed description of the register 
protocol and bit definition, refer to Section 3. 

6. If the above procedures function as described, the controller is ready for 
use. Either diagnostics or an operating system can be booted. For details 
on bootstrapping refer to Section 4. 

7. If the above procedures cannot be validated, consult the factory or your 
local representative for assistance. 
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functional description 



3.1 GENERAL 

This section describes device registers and command protocol for the 
PM-XCV21/XCV31. 

All software control of the PM-XCV21/XCV31 is performed by means of two device 
registers: the command and status (PMVCS) register and a multipurpose data 
buffer (PMVDB) register. These registers are normally assigned the bus address 
177170g and 177172g, respectively. The registers can be read or loaded, with a 
few exceptions, using any instruction referring to their addresses. 

The PMVCS register passes control information from the CPU to the controller 
and reports status and error information from the controller to the CPU. The 
PMVDB is provided for additional control and status information between the CPU 
and the controller. The information that is present in the PMVDB at any given 
time is a function of the controller, operation in progress. 

The controller contains a sector buffer capable of storing a complete sector. 
For read/write operations the buffer is either "filled" before a write command 
or "emptied" after a read command under DMA control. During a write command, 
the controller locates the desired sector, and the buffer information is 
transferred to the diskette. During a read operation, the desired sector is 
located, and the sector data are transferred to the buffer. 


3.2 REGISTER DEFINITIONS 


3.2.1 PMVCS - COMMAND AND STATUS REGISTER (177170g) 

The format of the PMVCS register is shown below. Functions are initiated by 
loading the commands into bits 1, 2, and 3 of this register and setting bit 0 
to 1. When not busy, bit 5=1. Command protocol is discussed in detail in 
Section 3.3. 
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Bit 

15 

14 


12-13 

11 

10 

09 

08 

07 


Description 


ERROR: This bit is set by the controller to indicate that an error 
has occurred during an attempt to execute a command. This bit is 
cleared by the initiation of a new command or by setting the 
initialize bit. When an error is defected, the PMVCS is read into 
the PMVDB. This bit is a read-only bit. 

XCV2KRX) INITIALIZE: This bit is set by the program to initialize 
the controller without initializing all devices on the LSI-11 bus 
(Q-bus). This is a write-only bit. 


CAUTION 


Loading the lower byte of the PMVCS will 
also load the upper byte of the PMVCS. 

When this bit is set, the controller will negate Done and move the 
head position mechanism of drive 1 (if two drives are available) to 
track 0. When completed, the controller will repeat the operation 
on drive 0. 

The controller will then clear the error and status register, set 
Initialize Done, and set Drive Ready if drive 0 is ready. Finally, 
the controller will read sector 1, track 1, of drive 0. 

EXTENDED ADDRESS BITS: These bits are used to specify an extended 
bus address. Bit 12 = MA16. Bit 13 = MA17. These are write-only 
bits. 

RXV02: This bit is asserted by the controller to indicate that 
this is an RXV02 type system. This is a read-only bit. 

RESERVED: Must be written as a zero. 

HEAD SELECT: This bit selects one of the two possible sides of the 
disc for execution of the desired function. When cleared, side 0 
is selected; when set, side 1 is selected. This is a read/write 
bit. 

DENSITY SELECT: This bit selects either single or double density 
operation. When cleared, single density is selected; when set, 
double density is selected. This is a read/write bit. 

TRANSFER REQUEST: This bit signifies that the controller needs 
data or has data available. This is a read-only bit. 
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Bit Description 


06 INTERRUPT ENABLE: This bit is set by the program to enable an 

interrupt when the controller has completed an operation and 
asserted the Done bit. The condition of this bit is cleared by 
initialize. This is a read/write bit. 


05 


DONE: This bit indicates the completion of a function. Done will 
generate an interrupt when asserted if interrupt enable (PMVCS bit 
6) is set. This is a read-only bit. 


04 


UNIT SELECT: This bit selects one of the two possible discs for 

execution of the desired function. This is a read/write bit. 


03-01 


FUNCTION SELECT: These bits code one of the eight possible 

functions described in detail within this section. These are 
write-only bits. 


000 

Fill Buffer 

001 

Empty Buffer 

010 

Write Sector 

Oil 

Read Sector 

100 

Set Media Density/Format 

101 

Read Status 

110 

Write Deleted Data Sector 

111 

Read Error Code 


00 


GO: Initiates a command to the controller. This is a write-only 

bit. 


3.2.2 PMVDB - DATA BUFFER (177172 8 ) 

This register serves as a general purpose data path between the controller and 
the LSI-11. It will represent one of six registers, according to the protocol 
of the function in process. These registers include the PMVDB, PMVTA, PMVSA, 
PMVWC, PMVBA, and PMVES. 

This register is a read/write register if the controller is not in the process 
of executing a command (i.e., it may be manipulated without affecting the 
controller). When the controller is executing a command, this register can 
only be written to or read from when PMVCS bit 7 (TR) is set. 
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• Data Buffer Register (PMVDB) 

All information transferred to and from the floppy media passes through the 
PMVDB register and is addressable only under the protocol of the function in 
progress. 

15 14 13 12 11 10 9 3 7 6 5 4 3 2 1 ff 


READ/WRITE DATA 

PMVDB FORMAT 


• Track Address Register (PMVTA) 

This register is loaded to indicate on which of the 115s (77 decimal) tracks 
a given function is to operate. It can be addressed only under the protocol 
of the function in progress. Bits 8 through 15 are not used and are 
ignored. 



PMVTA FORMAT 


• Sector Address Register (PMVSA) 

This register is loaded to indicate on which of the 32g (26 decimal) sectors 
a given function is to operate. It can be addressed only under the protocol 
of the function in progress. Bits 8 through 15 are not used and are 
ignored. 



NOT USED 


1-328 


PMVSA FORMAT 
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Word Count Register (PMVWC) 

This 8-bit register is loaded with the number of words (maximum of 128 
decimal) to be transferred. At the end of each transfer, the word count 
register is decremented. When the contents of the register are decremented 
to zero, transfers are terminated; Done is set (PMVES bit 5); and, if 
enabled, an interrupt is requested. If the word count is greater than the 
limit for the density specified, the controller asserts a Word Count 
Overflow (bit 10 of the PMVES). This register can be addressed only under 
the protocol of the function in progress. Bits 8 through 15 are not used 
and are ignored. 


IS 14 13 12 11 10 9 8 7 S 5 4 3 2 1 a 



NOT USED 0 -200g 


PMVWC FORMAT 


Bus Address Register (PMVBA) 

This register is used to generate the bus address which specifies the 
location to and from which data are to be transferred. The register is 
incremented after each transfer. It will increment across 32K boundary 
lines via the extended address bits in the control and status register. 
Systems with only 16 address bits will "wraparound" to location zero when 
the extended address bits are incremented. This register can be addressed 
only under the protocol of the function in progress. Bit 0 is not used and 
is ignored. 


15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 H 



PMVBA FORMAT 


Error and Status Register (PMVES) 


This register contains the current error and status conditions of the drive 
selected by bit 4 (Unit Select) of the PMVCS. This read-only register can 
be addressed only under the protocol of the function in progress. The PMVES 
is loaded in the PMVDB upon completion of a function. 
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Bit | Description 

Not Used 

NONEXISTENT MEMORY ERROR: This bit is asserted by the controller 
when the memory address specified for a DMA operation is 
nonexistent. 

10 WORD COUNT OVERFLOW: This bit indicates that the word count 

specified is greater than the limit for the density selected. 
Upon detecting this error, the controller terminates the fill or 
empty buffer operation and asserts the Error and Done bits. 

09 HEAD SELECT: This bit indicates the side currently selected. If 

cleared, it indicates side 0; if set, it indicates side 1. 

08 UNIT SELECT: This bit indicates the drive currently selected. 

If cleared, it indicates drive 0; if set, it indicates drive 1. 

07 DRIVE READY: This bit is asserted if the unit currently selected 

exists, is properly supplied with power, has a diskette installed 
correctly, has its door closed, and has a diskette up to speed. 
This bit is only valid when retrieved via a read status function 
or at the completion of initialize when it indicates the status 
of drive 0. 

06 DELETED DATA: During data recovery, the identification mark 

preceding the data field was decoded as a deleted data mark. 

05 DRIVE DENSITY: The bit indicates the density of the diskette in 

the selected drive. When zero, it indicates single density; when 
set to one, it indicates double density. 

04 DENSITY ERROR: A density error was detected as the information 

was retrieved from the data field of the diskette (a density 
error occurs when the density selected differs from that of the 
data field). Upon detecting this error, the controller loads the 
PMVES into the PMVDB and asserts the Error and Done bits. 

03 ACL0 - This bit is set by the controller to indicate a power 

failure. 

02 INITIALIZE DONE: This bit is asserted to indicate completion of 

the initialize routine, which can be caused by system power 
failure or programmable LSI-11 bus initialize. 

01 SIDE READY: This bit is asserted by the controller when a 

double- sided drive is selected, is ready, and has double-sided 
media inserted. The assertion of this bit indicates that side 1 
of the selected drive is available for read and write operations. 


15-12 

11 


3-6 



HA 703530-A 


Bit 

Description 

00 

CRC ERROR: A cyclic redundancy check error was detected, as 
information was retrieved from a data field of the diskette. The 
information stored in the buffer should be considered invalid. 
Upon detection of this error, the controller loads the PMVES into 
the PMVDB and asserts the Error and Done bits. 


3.2.3 EXTENDED STATUS REGISTERS 


The controller has four internal status words/registers. These registers 
provide specific error information in the form of error codes as well as drive 
status information, depending upon the general error type. The registers can 
be retrieved by a read error code function as described in Subsection 3.3.8. 


Word 1 <7:0> 
Octal Code 


Definitive Error Code 

Error Code Meaning 


040 

050 

070 

120 

150 

160 

170 

200 

240 

250 

260 

270 

300 

310 


Tried to access a track greater than 76. 

Home was found before desired track was reached. 

Desired sector could not be found after looking at 52 
headers (2 revolutions). 

A preamble could not be found. 

The header track address of a good header does not 
compare with the desired track. 

Too many tries for an index address mark (IDAM) 
(identifies header). 

Data AM not found in allotted time. 

CRC error on reading the sector from the disc. 

Density error 

Wrong key word for Set Media Density command 
Illegal data address mark (AM). 

Invalid power OK (POK) during write sequence. 

Drive not ready. 

Drive write protected. 
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• Word 1 - Not Used 

This register is always cleared by the controller. 

• Word 2 - Current Track Address of Drive 0 

This register is cleared during the initialize command in order to synchro¬ 
nize with actual track position. The register is updated with each seek on 
drive 0 and maintains current track position. 

• Word 2 <15:8> - Current Track Address of Drive 1 

This register is cleared during the initialize command in order to 
synchronize with actual track position. The register is updated with each 
seek on drive 1 and maintains correct track position. 

• Word 3 <7:0> Target Track of Current Disc Access 

If legal, the track specified for the last read/write command is saved in 
this register. 

• Word 3 <15:8> Target Sector of Current Disc Access 

The sector specified for the last read/write command is saved in this 
register. 

• Word 4 <15:8> Track Address of Selected Drive 

This register contains the track address read from the sector header of the 
desired sector during the last read/write command. 

• Word 4 <7:0> - Not used 


3.3 COMMAND PROTOCOL 

Data storage and recovery, using the PM-XCV21/XCV31 controller is accomplished 
by careful manipulation of the PMVCS and PMVDB registers according to the 
strict protocol of the individual functions. The penalty for violation of 
protocol can be permanent loss of data. Each of the functions are encoded and 
written into the command and status register bits 1-3 as described in 
Subsection 3.2.1. The detailed protocol for each function is described in the 
following paragraphs. 


/ 
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3.3.1 FILL BUFFER (000) 

This function is used to fill the controller buffer with data from the host 
processor. The number of words to transfer is specified by the host. The 
command density bit determines the buffer size (64 or 128 words). The 
controller zero-fills the remaining buffer space. If the word count is too 
large for the density selected, the function is aborted, Error and Done are 
asserted, and the Word Count Overflow bit is set in the PMVES. 

The contents of the buffer may be written on the diskette with a subsequent 
write sector command or returned to the host processor, using an empty buffer 
command. 

When the command is loaded, PMVCS bit 5 (Done) is negated. PMVCS bit 8 
(density) must be set to define the buffer size. PMVCS bits 12 and 13 
(extended address bits) must also be asserted to define the extended memory 
segment used with the buffer address to form the absolute memory address of the 
data to be transferred. PMVCS bit 4 (unit select) and bit 9 (head select) are 
ignored since no drive operation is required. When PMVCS bit 7 transfer 
request (TR) is first asserted, the program must move the word count into the 
PMVDB which will negate TR. 

When the controller again asserts TR, the program must move the buffer address 
into the PMVDB. The controller then negates TR, initiates a direct memory 
access (DMA) cycle, and transfers the first word from the host processor to the 
controller buffer. At the end of the transfer, the word count register is 
decremented, and the buffer address is incremented by two. This cycle is 
repeated until the word count register becomes zero. The controller zero-fills 
the remaining buffer space, sets the Done bit, and if enabled, causes an 
interrupt request. After Done is asserted, the PMVES is moved into the PMVDB. 

During the Data Transaction, if any non-existent memory is addressed, the 
controller will time out and abort the function. The Error and Done bits will 
be asserted. PMVES bit 11 (NXM) will be set, and the PMVES will be moved into 
the PMVDB, and if enabled, an interrupt request will be generated. 

3.3.2 EMPTY BUFFER (001) 

This function is used to transfer the contents of the controller to the host 
processor. The number of words to transfer is specified by the host. The 
command density bit determines the maximum legal word count. If the word count 
specified is too large for the density selected, the function is aborted, Error 
and Done are asserted, and the Word Count Overflow bit is set in the PMVES. 

The contents of the buffer may be transferred to the host as many times as 
desired or may be written on the diskette with a subsequent write sector 
command. Unless a fill buffer or read sector command is issued, the controller 
buffer is not destroyed. 
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When the command is loaded, PMVCS bit 5 (Done) is negated; PMVCS bit 8 
(density) must be set to allow the proper word count limit. PMVCS bits 12 and 
13 (extended address bits) must also be asserted to define the extended memory 
segment used with the buffer address to form the absolute memory destination 
address. PMVCS bit 4 (unit select) and bit 9 (head select) are ignored since 
no drive operation is required. When PMVCS bit 7 (TR) is.first asserted, the 
program must move the word count into the PMVDB which will negate TR. When the 
controller again asserts TR, the program must move the buffer address into the 
PMVDB. The controller then negates TR, initiates a DMA, and transfers the 
first word of the buffer to the host processor. At the end of the transfer, 
the word count register is decremented, and the buffer address register is 
incremented by two. This cycle is repeated until the word count register 
becomes zero. The controller then sets the Done bit and, if enabled, causes an 
interrupt request. After Done is asserted, the PMVES is moved into the PMVDB. 

During the DMA transaction, if any non-existent memory is addressed, the 
controller will time-out and abort the function. The Error and Done bits will 
be asserted. PMVES bit 11 (NXM) will be set, and the PMVES will be moved into 
the PMVDB. If enabled, an interrupt request will be generated. 

3.3.3 WRITE SECTOR (010) 

This function is used to locate a desired track and sector and write the sector 
with the contents of the internal sector buffer. When the PMVCS is loaded with 
this command, the PMVES is cleared, and both the TR and Done bits are negated. 
When TR is first asserted, the program must load the desired sector address 
into the PMVDB which will negate TR. When TR is again asserted, the program 
must load the desired track address into the PMVDB which will negate TR. The 
controller then seeks the desired track and attempts to locate the desired 
sector. The desired track is compared with the track field of the sector 
header. If they do not match, the operation is aborted, the Error and Done 
bits are asserted, the PMVES is moved into the PMVDB, and if enabled, the 
controller will assert an interrupt request. 

If the densities agree but the controller is unable to locate the desired 
sector within two diskette revolutions, the controller will abort the opera¬ 
tion, move the contents of RMVES into PMVDB, assert the Error and Done bits, 
and if enabled, assert an interrupt request. 

If the desired track and sector are located and the densities agree, the 
controller will write the contents of the internal sector buffer followed by a 
CRC character in the selected density. The controller completes the operation 
by moving the PMVES to the PMVDB, asserts Done, and if enabled, asserts an 
interrupt request. 
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CAUTION 


The contents of the internal sector 
buffer are lost during a power failure. 
However, after power is brought back to 
normal, a write sector command will cause 
the random contents of the buffer to be 
written on the diskette with a valid CRC 
character. 


Note 

The contents of the sector buffer are not 
destroyed by a write sector operation. 


3.3.4 READ SECTOR (Oil) 

This function is used to locate the desired track and sector and transfer the 
contents of the data field into the controller's internal sector buffer. When 
the PMVCS is loaded with this command, the PMVES is cleared, and both the TR 
and Done bits are negated. When TR is first asserted, the program must load 
the desired sector address into the PMVDB which will negate TR. When TR is 
again asserted, the program must load the desired track address into the PMVDB 
which will negate TR. 

Both the TR and Done bits remain negated while the controller attempts to 
locate the desired sector. If after two revolutions the controller is unable 
to locate the desired sector, the operation is aborted. The controller will 
move the PMVES into the PMVDB, assert the Error and Done bits, and if enabled, 
assert an interrupt request. 


When the desired sector is located, the controller will then compare the 
desired track with the track field of the sector header. If they do not match, 
the operation is aborted. The Error and Done bits are asserted, the PMVES is 
moved into the PMVDB, and if enabled, the controller will assert an interrupt 
request. 


If the desired track and sector are reached, the controller reads the data 
address mark and determines the diskette density. If the diskette density does 
not agree with the function density, the operation is aborted. PMVES bit 4 
(Density Error) is set, and the PMVES is moved into the PMVDB. The Error and. 
Done bits are set, and if enabled, the controller asserts an interrupt request. 
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If a legal data address mark is located and the densities of the diskette and 
function agree, the controller will read the data from the sector into the 
internal buffer. If the data address mark indicated a deleted data field, 
PMVES bit 6 (DD) is set. As data are stored in the internal buffer, a CRC is 
computed on the data, and the CRC bytes is recorded. A non-zero result 
indicates a read error. When a CRC error is encountered, the controller sets 
PMVES bit 0 (CRC), moves the PMVES into the PMVDB, asserts the Error and Done 
bits, and if enabled, asserts an interrupt request. 

If the desired sector is located, the density of the diskette and function 
agree, and the data are transferred with no CRC error, the controller will 
assert Done, and if enabled, will assert an interrupt request. 


3.3.5 SET MEDIA DENSITY (100) 

This function is dual purpose. The controller can set the media density by 
rewriting all the data address marks (single or double density) and writing 
zero data fields in the selected density. The controller can also "reformat" 
the entire diskette by rewriting both the sector headers and the data fields. 
The data fields are written in the selected density preceded by the 
corresponding data address mark. Both commands are initiated by the set media 
function but differ in the keyword required by the controller to execute the 
command. 

When the PMVCS is loaded with the command, the PMVES is cleared and the Done 
bit is negated. When TR is set, the program must respond with a keyword. This 
keyword must be deposited in the PMVDB to complete the protocol. When the 
controller recognizes this character, it begins executing the command. If an 
illegal keyword is used, the operation is aborted. The PMVES is moved into the 
PMVDB, the Error and Done bits are set, and if enabled, the controller asserts 
an interrupt request. 

If the keyword used is a 111 g , the controller initiates a set media density 
operation. This operation starts at track 0, sector 1. Each sector header is 
located, and a write operation is initiated. A data field is written with zero 
data in the density selected. If an error occurs reading any header, the 
operation is aborted. The PMVES is moved into the PMVDB, the Error and Done 
bits are set, and if enabled, the controller asserts an interrupt request. If 
the operation is successfully completed, Done is set, and if enabled, the 
controller asserts an interrupt request. 
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If the keyword used is a 222g , the controller initiates a format operation. 
This function starts at the physical index of track 0. Each track is written 
first with an index address mark, then 26 sector headers are written 
sequentially about the track. When each track has been written, the controller 
initiates a set media density function as described above. 

The following input string will format the selected unit in the desired 
density. 

777170 4040 XXXX <LF> 

177172 000000 222 <CR> 


CAUTION 


The set media density function takes 
about 15 seconds, and the format function 
takes about 45 seconds. Neither should 
be interrupted. If either operation is 
interrupted, an illegal diskette has been 
generated, and the operation should be 
repeated. If an error occurs during a 
set media density function or a format 
function, an illegal diskette has been 
generated. The operation should be 
repeated. 


3.3.6 READ STATUS (101) 

This function is used to update the drive status information and is initiated 
by loading the command into the PMVCS. The Done is negated. PMVES bit 7 
(Drive Ready) is updated by sampling the drive ready status line. Drive 
density is updated by loading the head of the selected drive and reading the 
first data address mark. The controller then moves the PMVES into the PMVDB, 
asserts Done, and if enabled, asserts an interrupt request. This operation 
requires about 250ms to complete. 


3.3.7 WRITE DELETED DATA SECTOR (110) 

This operation is identical to Write Sector (010) with one exception. The data 
address mark preceding the data is not the standard data address mark. A 
single or double density deleted data address mark is written according to the 
density of the function. 
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3.3.8 READ ERROR CODE (111) 

This function is used to retrieve the extended status registers and is 
initiated by loading the PMVCS with the command. The Done bit is negated. 
When TR is asserted, the program must load the Bus Address into the PMVDB which 
negates TR. The controller assembles one word at a time and, under DMA 
control, transfers them to memory starting at the address specified. 

If non-existent memory is encountered during the transfer, the operation is 
aborted. The Error and Done bits will be asserted, PMVES bit 11 (NXM) will be 
set, and the PMVES will be moved into the PMVDB. If enabled, an interrupt 
request will be generated. 

When all four words have been transferred, the Done bit is set, and if enabled, 
an interrupt request is generated. 
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controller operations 


4.1 GENERAL 

This section provides the user pertinent information concerning the description 
and use of the controller functions. The functions covered include: 
bootstrapping, formatting, fill/write operation, read/empty operations, write 
current control, write precompensation, and power fail protection. The section 
also reviews operation with an RT-11 operating system. 



4.2 BOOTSTRAPPING THE CONTROLLER 


If the bootstrap is enabled as described in Subsection 2.1.3, the controller 
will respond to the standard bootstrap address 173000s • The controller is 
bootstrapped by typing 173000G while in console ODT. This causes a bus INIT 
and transfers program execution to location 173000g. An alternate method is to 
strap the LSI-11 processor to power-up in Mode 2. In this mode, when a power- 
up occurs, the processor automatically starts execution at 1730003 . Power-up 
strapping procedures for the LSI-11 processor can be found in the Microcomputer 
Processor Handbook*. 

To boot either a single or double density diskette, use the following 
procedure: 

1. Place the diskette in drive 0. 

2. If the processor is strapped for power-up Mode 2, operate the INIT (boot) 
switch or cycle DC power OFF and ON. 

3. If the processor is not strapped for power-up Mode 2 while in console ODT, 
type 173000G. 

4.2.1 BOOTSTRAP OPERATION 

The bootstrap is not a standard ROM program. It uses the controller's micro¬ 
processor to capture the bus; to read block 0 of the diskette into memory 
starting at location 0; and finally to transfer program execution to memory 
location 0. 


*Published by Digital Corporation in 1979. Maynard, Mass. 01754 
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Any attempt to read location 1730008 will result in a non-existent memory trap. 
The controller only responds to this address immediately after a bus INIT. For 
this reason the bootstrap is called "transparent". When the processor attempts 
to fetch location 173000s following a bus INIT, the controller responds by 
passing the processor a "CLEAR R0" instruction. The processor clears R0 and 
then attempts to fetch location 1730028- The controller passes the processor a 
"LOAD IMMEDIATE" instruction with R1 as the destination. The processor then 
attempts to fetch the source operand from location 1730048 . The controller 
passes the device address 177170s if the standard address is selected, or 
1771748 if the alternate address is selected. The processor moves the address 
into R1 and then attempts to fetch location 1730068 • The controller first 
asserts a Direct Memory Access Request (DMR) then passes the processor a "CLEAR 
PC" instruction. Before the processor executes the instruction it passes bus 
mastership to the controller. The controller moves a "BRANCH TO CURRENT 
LOCATION" instruction (777g) into memory location 0 under DMA control. When 
the controller releases bus mastership the processor executes the "CLEAR PC" 
instruction and, in so doing, transfers program execution to location 0. The 
processor is thus forced to loop at location 0. The controller initiates a 
Read Status function on drive 0 to determine diskette density. If the diskette 
is single density, the controller reads sectors 1,3,5, and 7 of track 1 of 
drive 0 into locations 2 through 176, 200 through 376, 400 through 576, and 600 
through 776, respectively. If the diskette is double density, the controller 
reads sectors 1 and 3 of track 1 of drive 0 into locations 2 through 376, and 
400 through 776, respectively. Finally, the controller loads location 0 with a 
no operation (NOP) instruction (2408) thus forcing the processor to execute the 
system bootstrap. If there is no diskette in drive 0, nothing will be 
transferred to memory, and the processor will continue to loop at location 0 
until halted. 


4.3 FORMAT OPERATIONS 


The controller has the capability of formatting diskettes in a specified 
density. The formatting is accomplished on two passes. During pass 1, an 
index address mark is written on track 0 following the index hole. Twenty-six 
sector headers, appropriately spaced, are written following the index address. 
Each of the remaining 76 tracks is written in the same manner. When track 76 
is completed, pass 2 is initiated. The controller seeks track 0 and write zero 
data field in sector 1, using the selected density. The remaining sectors are 
written in the same manner. 

The format command selects diskette density, unit, and side (for dual headed 
drives). Table 4-1 lists the various command word formats. 
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TABLE 4-1. COMMAND WORD FORMATS 



Unit 0 

Unit 1 

Single Density Side 0 

Hg 

31 8 

Single Density Side 1 

1011 8 

1031 g 

Double Density Side 0 

411g 

431g 

Double Density Side 1 

1411 g 

1431g 


Figure 4-1 illustrates a format subroutine. The format command is loaded into 
PMVCS. When TR is set, the keyword 222g is loaded into PMVDB. When the 
diskette has been formatted, a return is made. 


FORMAT: 

MOV 

#11, CMD 

FORMAT 


BIS 

DENS, CMD 

DENSITY 


BIS 

UNIT, CMD 

UNIT 


BIS 

SIDE, CMD 

SIDE 


MOV 

CMD, @#PMVS 

SELECT FUNCTION 


JSR 

PC, TRWAIT 

WAIT FOR TR 


MOV 

#222, @#PMVD 

KEYWORD 


JSR 

PC, DNWAIT 

WAIT FOR DONE 


TST 

@#PMVC 

ERROR 


BMI 

FRMERR 

BR IF SO 


RTS 

PC 


FRMERR: 





Figure 4-1. Format Subroutine 


Alternatively, a diskette can be formatted using console ODT. Open the CS 
register and deposit the appropriate command, then deposit the format key word 
222g into the DB register. The following is an example of formatting unit 0 
side 0 in double density: 


177170/ 004040 411 <LF> 

177172/ 000000 222 <CR> 
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4.4 FILL/WRITE OPERATIONS 

Figure 4-2 illustrates subroutines to write data on a diskette which is done by 
performing a fill buffer operation followed by a write sector. 

The Fill Buffer command, specifying single or double density, is loaded into 
the PMVCS. When TR is set, the word count is loaded into the PMVDB. When TR 
is again set, the bus address of the data is loaded into the PMVDB. A return is 
made when the controller's sector buffer is filled. The Write Sector command 
(specifying density, unit and side) is loaded into the PMVCS. When TR is set, 
the sector address is loaded into the PMVDB. When TR is again set, the track 
address is loaded into the PMVDB. When the contents of the controller's sector 
buffer are written at the selected sector, a return is made. 

FILLBF: 


MOV 

#1, CMD 

;FILL BUFFER 

BIS 

DENS, CMD 

;DENSITY 

MOV 

CDM, @#PMV CS 

; SELECT FUNCTION 

JSR 

PC TRWAIT 

;WAIT FOR TR 

MOV 

COUNT, @#PMVDB 

;WORD COUNT 

JSR 

PC, TRWAIT 


MOV 

#BUFOUT, @#PMVDB 

;BUS ADDRESS OF DATA 

JSR 

PC, DNWAIT 

;WAIT FOR DONE 

TST 

@#PMVCS 

;ERROR 

BMI 

ERFIL 

;BR IF SO 

RTS 

PC 



ERFIL: 
WSECT: 


MOV 

#5, CMD 

WRITE, SECTOR 

BIS 

DENS, CMD 

DENSITY 


BIS 

UNIT, CMD 

UNIT 


BIS 

SIDE, CMD 

SIDE 


MOV 

CMD, @#PMVCS 

SELECT FUNCTION 

JSR 

PC, TRWAIT 

WAIT FOR 

TR 

MOV .. 

SECTOR, @#PMVDB 

SECTOR 


JSR 

PC TRWAIT 



MOV 

TRACK @#PMVDB 

TRACK 


JSR 

PC, DNWAIT 

WAIT FOR 

DONE 

TST 

@# PMVCS 

ERROR 


BMI 

WSERR 

BR IF SO 


RTS 

PC 




WSERR: 


Figure 4-2. Write Data Subroutines 
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4.5 READ/EMPTY OPERATIONS 

Figure 4-3 illustrates subroutines to read data from a diskette; this is 
accomplished by performing a Read Sector operation followed by an Empty Buffer 
operation. 

The Read Sector command (specifying density, unit and side) is loaded into the 
PMVCS. When TR is set, the sector address is loaded into the PMVDB. When TR 
is again set, the track address is loaded into the PMVDB. When the contents of 
the selected sector are read into the controller's sector buffer, a return is 
made. 

The Empty Buffer command, specifying density, is loaded into the PMVCS. When 
TR is set, the word count is loaded into the PMVDB. When TR is again set, the 
bus address of the storage buffer is loaded into the PMVDB. A return is made 
after the contents of the controller's buffer are transferred to the memory 


buffer. 




RSECT: 

MOV 

#7, CMD 

READ SECTOR 


BIS 

DENS, CMD 

DENSITY 


BIS 

UNIT, CMD 

UNIT 


BIS 

SIDE, CMD 

SIDE 


MOV 

CMD, @#PMVCS 

SELECT FUNCTION 


JSR 

PC, TRWAIT 

WAIT FOR TR 


MOV 

SECTOR, @#PMVDB 

SECTOR 


JSR 

PC, TRWAIT 



MOV 

TRACK, @#PMVDB 

TRACK 


JSR 

PC, DNWAIT 

WAIT FOR DONE 


TST 

@#PMVCS 

ERROR 


BMI 

RSERR 

BR IF SO 


RTS 

PC 


RSERR: 




EMPBF: 

MOV 

#3, CMD 

EMPTY BUFFER 


BIS 

DENS, CMD 

DENSITY 


MOV 

CMD, <2#PMVCS 

SELECT FUNCTION 


JSR 

PC, TRWAIT 

WAIT FOR TR 


MOV 

COUNT, @#PMVDB 

WORD COUNT 


JSR 

PC, TRWAIT 



MOV 

#BUFFIN, @#PMVDB 

BUS ADDRESS FOR DATA 


JSR 

PC, DNWAIT 

WAIT FOR DONE 


TST 

@#PMVCS 

ERROR 


BMI 

EREMP 

BR IF SO 


RTS 

PC 



EREMP: 


Figure 4-3. Read Data Subroutines 
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4.6 WRITE CURRENT CONTROL 

The controller provides a Write Current Control signal (TG43) which is asserted 
whenever a track address greater than 43 is accessed. This signal is required 
by some drives to reduce the effects of write saturation on the inner tracks. 
Since the Shugart 800 series drives do not require this signal, the controller 
is shipped with this feature disabled. However, Shugart 850 series double¬ 
sided drives require this signal (refer to the Shugart double-sided diskette 
storage drive manual). This signal is provided on pin 2 of the 50-pin ribbon 
connector and is enabled according to Subsection 2.1.5. 


4.7 WRITE PRECOMPENSATION 

Bit shift occurs on both single and double density diskettes. This shift is 
more noticeable with double density due to the smaller bit cell size and 
corresponding data and clock windows. Some aspects of bit shift are 
predictable and are dealt with by the precompensation scheme implemented in 
this controller; unpredictable effects are reduced by using phase lock loop 
(PLL) techniques. 

Predictable bit-shift effects result from normal read/write operation. Data 
are recorded by flux changes in the gap of the read/write head. These flux 
changes produce changes in magnetization in the oxide coating on the media. 
When reading the media, the changing magnetization induces current in the 
read/write head. Since this change in current is not instantaneous, it takes a 
finite time to build up to a peak and return to zero. When the magnetic flux 
changes are close together, the previous current transition may not reach zero 
before a second transition occurs. The summation of current pulses produces 
shifted peaks. Because the flux changes are closer together on the inner 
tracks (43 through 76), the bit shift is greater in this area. Values of up to 
_+350ns are typical. 

Another cause of bit shift are variations in disk drive rotational speed. The 
specified +2% variation will produce bit shifts of +40ns. Incomplete erasure 
of previously recorded data can produce bit shifts of up to +50ns. Other 
miscellaneous components of bit shift include instantaneous speed variation, 
electrical noise, radial track alignment, and nonsymmetry of the read/write 
head and associated electronics. These effects can produce up to +10ns of bit 
shift, bringing the total effect to +450ns. 

Since the data/clock window for double density is only 1000ns, a +450ns bit 
shift leaves only a 50ns margin before soft errors begin to occur. To improve 
this margin, the controller incorporates a scheme to recognize the data 
patterns which produce excessive bit shift and introduces a compensating bit 
shift. For tracks greater than forty-three, the recorded bits are shifted 
165ns early or late, as determined by the two previously recorded bits and the 
subsequent two bits to be recorded. The controller also incorporates a 
phase-locked data recovery scheme which dynamically adjusts the recovery clock 
frequency to the data, reducing bit shifts due to rotational speed errors. 
These two features improve data recovery margins by 175ns or more, providing 
approximately 225ns of margin. 
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4.8 POWER FAIL PROTECTION 

The controller continuously monitors both the BPOK and BDCOK bus signals. 
Refer to the Microcomputer Processor Handbook for detailed descriptions of 
these signals. When asserted, BPOK signals an impending DC power failure and 
guarantees 4ms of operation before BDCOK is asserted and DC power fails. 
Assertion of BDCOK indicates invalid DC power. This signal is hardwired in the 
controller as an interlock on the Write Gate signal. When BDCOK is asserted, 
the Write Gate signal is blocked and write operations are prevented. 

Before initiating a write sequence, the controller interrogates the BPOK line. 
If an impending DC failure is indicated, the operation is aborted. 
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